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(54) Method and device for forming a tone waveform by combined use of different waveform 
sample forming resolutions 



(57) The number of waveform samples per unit 
time, i.e., waveform sample forming resolution is varia- 
bly set depending on characteristics of a tone to be gen- 
erated, such as construction of harmonic components 
in the tone. The number is increased for a tone or por- 
tion (e.g. , attack portion) of a tone containing a relatively 
great number high-order harmonic components. Con- 
versely, for a tone or portion (e.g., sustain portion) of a 
tone containing fewer high-order harmonic components, 
the number is decreased. By thus variably setting the 



waveform sample resolution, a process for arithmeti- 
cally forming waveform sample data can be performed 
without involving significant waste. The waveform sam- 
ple forming resolution may be variably set independ- 
ently for each of tone generation channels. Data 
compression can be achieved by storing the waveform 
data with the waveform sample forming resolution vari- 
ably set for each of different waveform segments. 
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Description 

The present invention relates to a method for forming tone waveform samples on the basis of waveform forming 
calculations performed via an arithmetic processing device. 
5 The present invention also relates to a method for compressing waveform data to be stored in a memory in an elec- 
tronic musical instrument or other tone reproducing device provided with a waveform-memory-based tone generator. 

In conventional tone generators capable of simultaneously generating tones in a plurality of channels where tone 
waveform samples are arithmetically formed by use of an arithmetic processing device, the number of waveform sam- 
ples to be arithmetically formed per predetermined unit time (hereinafter referred to as a ''waveform sarrple forming res- 
10 olution") in the individual tone generating channels is kept fixed for each of the channels. Also, the waveform sample 
forming resolution is kept fixed from the start to end of each tone, and no conventionally-known tone generators are 
designed to allow the waveform sample forming resolution to be varied during arithmetical formation of a tone. 

The term "waveform sample forming resolution" is used herein as a basic measure in describing the characteristic 
concept of the present invention, and a variation in the number of waveform samples to be arithmetically formed per 
is predetermined unit time will lead to a variation of the upper limit frequency in the frequency band covered by a gener- 
ated tone. 

If the waveform sample forming resolution is expressed in terms of the number of samples to be formed per second 
(equivalent sampling frequency), the upper limit frequency will correspond to about 1/2 of the sampling frequency 
according to the known sampling theorem. For example, if 128 samples are arithmetically formed for each unit time of 

20 1/375 second, the equivalent sampling frequency will be 1 28 x 375 = 48 (kHz) so that a generated tone can contain fre- 
quency components up to an upper limit of 24 kHz. In general, the tone quality depends on the waveform sample form- 
ing resolution because the sampling frequency is a factor determining the quality of a digital tone. 

The waveform sample forming resolution will directly determine an amount of tone waveform forming calculations 
per unit time, and the amount of necessary calculations will increase in direct proportion to the number of samples per 

25 unit time since the per-sample calculation does not differ significantly from one sample to another. That is, if the wave- 
form sample forming resolution is raised to enhance the quality of a tone, the amount of necessary calculations will 
increase and the calculations will sometimes become even impossible without the provision of large-scale circuitry. So, 
the trade-off between the waveform sample forming resolution and the circuitry scale has been an important factor in 
designing the tone generator 

30 However, as known, respective frequency bands of tone waveforms formed in the individual tone generating chan- 
nels generally differ depending on colors of tones to be generated. Thus, if a common fixed waveform sample forming 
resolution is used in the channels, there would arise a problem that calculations are wastefully performed up to an 
unnecessary frequency band for each of the channels forming a tone waveform that does not necessarily require a wide 
frequency band. If a waveform sample forming resolution is set to correspond to a tone waveform that does not require 

35 a wide frequency band, there would arise another pYbblem that tone waveform samples requiring a wide frequency 
band can not be formed. 

Further, in the case of a waveform from the start to end (start-to-end-waveform) of a decay tone, the attack portion 
covers a wide frequency band containing many harmonic components, while the sustain portion where attenuation has 
progressed to a considerable degree covers a less wide frequency band containing fewer harmonic components. If, in 
40 this case, a fixed waveform sample forming resolution is used for formation of a tone, calculations are wastefully per- 
formed up to an unnecessary frequency band for such a portion requiring no wide frequency band. Also, if a waveform 
sample forming resolution is set to correspond to a portion of the waveform that does not require a wide frequency 
band, there would arise the problem that tone waveform samples can not be formed for another portion requiring a wide 
frequency band. 

45 Further, in the waveform-memory-based tone generator where a plurality of tone waveforms are pre-recorded in 
the waveform memory, many tone waveforms generally have to be recorded if high-quality tones are desired, thus 
requiring a great waveform memory capacity. To address this inconvenience, there has been proposed various 
approaches so far to reduce the necessary memory capacity for storing the tone waveforms, one example of which is 
based on the fact that different tone waveforms normally have different frequency components. Specifically, it is pro- 

so posed that in the case of a tone waveform consisting of low-frequency components, the tone waveform should be sam- 
pled during recording by use of a low sampling frequency so as to reduce the number of sampling data so that the 
necessary waveform memory capacity is reduced. However, the recording sampling frequency may sometimes be var- 
ied for each of the different tone waveforms, in which case if any one of the tone waveforms is read out from the wave- 
form memory in accordance with predetermined frequency numbers (i.e., numerical numbers defining a pitch of a 

55 reproduced tone, which will hereinafter be referred to as n F numbers") determined solely by a note number to be 
sounded, relationships between the sampling frequency and readout timing would substantially differ among the tone 
waveforms, thus presenting a problem that a tone of a desire pitch can not be obtained. 

In addition, with the waveform-memory-based tone generator, where the use of F numbers allows a reproducing 
frequency to be finely controlled, a tone waveform can be read out at a desired pitch by just controlling the F numbers 
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in accordance with any of the recording sampling frequencies so as to compensate for a difference in the recording 
sampling frequencies. 

An attempt to reduce the necessary waveform memory capacity has been so far made in the above-mentioned 
manners. 

s Further, because of the fact that while high-frequency components such as harmonic components of a fundamental 
wave are contained in the attack portion of a waveform of a decay tone, the sustain portion has the harmonic compo- 
nents almost completely attenuated, what is left unattenuated in the sustain portion would be almost nothing but the 
fundamental wave, so that the sustain portion would consist of frequency components lower than the attack portion. 
Further, in the case of a tone color that affords an effect of gradually increasing brightness, the waveform has frequency 

10 components becoming increasingly higher although it does not have not-so-high frequency components at the begin- 
ning of sounding of a corresponding tone. 

However, in the past, the sampling frequency used in recording a start-to-end waveform of a tone was fixed to such 
a frequency to permit proper sampling of the highest-frequency component without involving unwanted aliasing noise, 
although the sampling frequency was made variable among different tone waveforms. With such a fixed recording sam- 

15 pling frequency, even waveform data of an unnecessary frequency band would wastefully be recorded into the wave- 
form memory, with the result that the waveform memory could not be used efficiently. 

It is therefore a first object of the present invention to provide a tone generating method for forming tone waveform 
samples on the basis of waveform forming calculations performed via an arithmetic processing device, which is capable 
of forming tone waveform samples of a wide frequency band efficiently without involving wasteful calculations. 

20 It is a second object of the present invention to provide a waveform data compressing method applicable to an elec- 
tronic musical instrument provided with a waveform-memory-based tone generator or other tone reproducing device, 
which is capable of effectively compressing waveform data to be recorded into the waveform memory. 

In order to accomplish the first object, the present invention provides a tone generating method for forming tone 
waveform samples on the basis of waveform forming calculations via an arithmetic processing device, which is charac- 

25 terized in that a resolution of the waveform forming calculations is determined independently for each of a plurality of 
tone generating channels in accordance with a character of a waveform to be formed in the channel and importance of 
the channel relative to other the channel. 

The present invention also provides a tone generating method for forming tone waveform samples on the basis of 
waveform forming calculations via an arithmetic processing device, which is characterized in that a resolution of the 

30 waveform forming calculations is varied during the calculations in accordance with a time-varying ratio of harmonic con- 
tent in a tone. 

The present invention also provides a tone generating method wherein tone forming calculations are performed for 
a plurality of tone generating channels so as to form waveform data of a plurality of tones corresponding to the chan- 
nels, and the method comprises a tone control step of generating first control data for, for each of the tone generating 

35 channels, designating a tonal characteristic of the waveform data to be formed in the channel, a calculation control step 
of generating second control data for, for each of the tone generating channels, designating a specific number of tone 
samples to be formed in the channel per unit time, a tone formation step of, for each of the tone generating channels, 
arithmetically forming waveform data of the tone corresponding to the channel in accordance with the tonal character- 
istic designated by the first control data and at a sample forming rate designated by the second control data, and a step 

40 of generating tones on the basis of the waveform data formed in the tone formation step for the plurality of tone gener- 
ating channels. 

In the above-mentioned tone generating method, the calculation control step generates second control data in cor- 
respondence with a time-varying tonal characteristic of waveform data to be formed in each of the channels. The cal- 
culation control step varies the second control data to be generated in correspondence with a time-variation in the tonal 

45 characteristic of the waveform data to be formed in each of the tone generating channels. Further, the first control data 
includes pitch information that designates a pitch of a tone to be generated in each of the tone generating channels, 
and the tone formation step converts the pitch information of each of the channels into a phase variation rate of the tone 1 
to be generated in accordance with the sample forming rate designated by the second control data. 

The present invention also provides a tone generating method for simultaneously generating at least two tones, 

so which comprises a first formation step of forming samples of a first tone waveform containing a great number of high- 
frequency components at a forming rate of N samples per unit time, a second formation step of forming samples of a 
second tone waveform containing a small number of high-frequency components at a forming rate of M samples per 
unit time (where M is smaller than N), a step of subjecting the M samples of the second tone waveform to an interpola- 
tion operation so as to provide N samples of the second tone waveform, a mix step of sequentially adding the N sam- 

55 pies of the first second tone waveform and the N samples of the second second tone waveform sample by sample so 
as to provide N samples of a mixed tone waveform, and a step of generating tones on the basis of the mixed tone wave- 
form provided by the mix step. 

The present invention also provides a tone generating method wherein tone forming calculations are performed for 
a plurality of tone generating channels so as to form waveform data of a plurality of tones corresponding to the chan- 
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nels, and which comprises a division step of dividing the plurality of tone generating channels into first and second 
groups, a first formation step of forming N samples of a tone waveform per unit time for each of the channels of the first 
group and sequentially adding the N samples between the channels so as to provide N samples of a first mixed wave- 
form, a second formation step of forming M samples of a tone waveform per unit time for each of the channels in the 
second group and sequentially adding the M samples between the channels so as to provide M samples of a second 
mixed waveform (where M is smaller than N), a step of subjecting the M samples of the second tone waveform to an 
interpolation operation so as to provide N samples of the second tone waveform, a mix step of sequentially adding the 
N samples of the first second tone waveform and the N samples of the second second tone waveform sample by sam- 
ple, so as to provide N samples of a mixed tone waveform, and a step of generating tones on the basis of the mixed 
tone waveform provided by the mix step. 

Because a waveform sample forming resolution can be determined, for each of the tone generating channels, 
depending on whether or not a tone waveform to be sounded therein is of a wide frequency band, or depending on rel- 
ative importance of the corresponding tone, the present invention can arithmetically form tone waveform samples irre- 
spective of whether a tone waveform to be sounded is of a wide frequency band or narrow frequency band, without 
involving wasteful calculations. Further, because the waveform sample forming resolution is raised for the attack portion 
of a decay tone in order to form a greater number of waveform samples and is lowered for the sustain portion to form a 
smaller number of waveform samples, wasteful calculations can be avoided so that waveform samples from the start to 
end of a tone can be formed efficiently without involving wasteful calculations. By thus saving waveform calculations for 
a specific tone generating channel, it is possible to increase the amount of waveform calculations for another tone gen- 
erating channel to thereby enhance the quality of a tone generated in that channel, and the number of channels capable 
of simultaneously generating tones can be increased. Moreover, because the invention can control the number of tone 
waveform samples to be formed per unit time independently for each channel, tones can be generated with different 
qualities in the channels. Also, it is allowed to reduce the amount of calculations for a specific channel which will present 
no significant effect even though the tone generated therein is of low quality. 

Further, in order to accomplish the second object, the present invention provides a waveform data compressing 
method which comprises an input step of inputting a waveform lasting for a predetermined period, a control step of var- 
ying a recording sampling frequency during the predetermined period, a sampling step of sampling the waveform by 
use of the recording sampling frequency so as to obtain waveform data, and a write step of sequentially writing into a 
memory the waveform data obtained by the sampling step. 

In the above-mentioned waveform data compressing method, the recording sampling frequency is varied stepwise 
at predetermined timing during the predetermined period. Alternatively, the recording sampling frequency may be var- 
ied gradually at predetermined timing during the predetermined period. 

The present invention also provides a waveform data compressing method which comprises an input step of input- 
ting a waveform lasting for a predetermined period, a control step of varying a recording sampling frequency during the 
predetermined period, a sampling step of sampling the waveform by use of the recording sampling frequency so as to 
obtain waveform data, a recording step of sequentially recording into a waveform memory the waveform data obtained 
by the sampling step, a designation step of designating a reproducing rate, a generation step of generating variation 
data corresponding to a pitch variation occurring in the waveform data recorded in the waveform memory due to a var- 
iation of the recording sampling frequency by the control step, a modification step of modifying the reproducing rate des- 
ignated by the designation step with the variation data, and a reproduction step of reading the waveform memory at a 
rate corresponding to the reproducing rate modified by the modification step. 

In the above-mentioned waveform data compressing method, if the waveform data are read out at a fixed rate, the 
variation data is data indicative of a frequency in a logarithmic region represented by the waveform data. The modifica- 
tion step performs addition or subtraction between the reproducing rate and the variation data. 

According to the waveform data compressing method arranged in the above-mentioned manner, the sampling fre- 
quency is raised for the attack portion of a tone to be recorded where the waveform data contain high frequency com- 
ponents and lowered for the sustain portion etc. where the waveform data contain not-so-high frequency components, 
so that waveform sample data to be recorded in the waveform memory can be effectively reduced in quantity and com- 
pressed to a substantial degree. As a result, the present invention can reduce a necessary storage capacity of the 
waveform memory and use the memory with enhanced efficiency. 

For better understanding of the above and other features of the present invention, the preferred embodiments of 
the invention will be described in detail below with reference to the accompanying drawings. 

In the accompanying drawings: 

Fig. 1 is a block diagram illustrating a exemplary structure of a tone generating device used to implement a tone 
generating method of the present invention; 

Fig. 2 is a diagram illustrating tone color data and waveform data areas provided in a RAM of Fig. 1 ; 

Fig. 3 is a diagram illustrating an input buffer area provided in the RAM of Fig. 1 ; 

Fig. 4 is a diagram illustrating a tone generator register area provided in the RAM of Fig. 1 ; 
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Figs. 5A to 5E are diagrams illustrating structures and operations of various output buffer areas. provided in the 
RAM of Fig. 1; 

Fig. 6 illustrates an example of waveform data from the start to end of a tone; 
Figs. 7A to 7D illustrate frequency spectra at various points of the waveform data of Fig. 6; 
5 Fig. 8 illustrates an example of time-variation of an original pitch in a start-to-end waveform of a tone; 

Fig. 9 illustrates an exemplary variation of a waveform sample forming resolution in relation to time during arithmet- 
ical formation of a ton; 

Fig. 10 illustrates an exemplary manner in which a reproducing frequency number is varied over time during arith- 
metical formation of a tone; 

w Fig. 1 1 is a timing chart explanatory of tone generator processing performed, by a CPU of Fig. 1 , to form a tone 
waveform; 

Fig. 1 2 is a flowchart of a main routine performed, by the CPU of Fig. 1 , in a software tone generator implementing 
the tone generating method of the present invention; 

Fig. 13 is a flowchart of a MIDI reception interrupt process carried out by the CPU; 
is Fig. 14 is a flowchart of a tone color selection event process for part 1 that is executed as an example of panel 
switch went processing in the main routine; 

Fig. 15A is a flowchart illustrating an exemplary detail of a note-on process that is performed in received data 
processing during the main routine; 

Fig. 15B is a flowchart illustrating an exemplary detail of a note-off process that is performed in received data 
20 processing during the main routine; 

Fig. 16, a flowchart illustrating a detail of the tone generator processing executed in the main routine; 

Fig. 1 7 is a flowchart illustrating a detail of channel control processing executed in the tone generator processing; 

Fig. 1 8 is a flowchart illustrating a detail of a waveform calculating process; 

Fig. 1 9 is a diagram illustrating an exemplary manner in which a recording sampling frequency is varied, in accord- 
25 ance with a waveform data compressing method of the present invention, when time-serial waveform data covering 
from the start to end of a single tone are recorded; 

Fig. 20 is a diagram illustrating an exemplary manner in which an original pitch is varied in accordance with the 
waveform data compressing method of the present invention; 

Fig. 21 is a diagram illustrating another exemplary manner in which the recording sampling frequency is varied in 
30 accordance with the waveform data compressing method of the present invention; 

Fig. 22 is a block diagram illustrating an exemplary arrangement for effecting waveform preparations to record, into 
a waveform memory, waveform sample data in accordance with the waveform data compressing method of the 
present invention; 

Fig. 23 is a block diagram illustrating a general structure of an electronic musical instrument including the waveform 
35 memory in which waveforrirrdata are recorded in compressed form according to the waveform data compressing 
method of the present invention; 

Fig. 24 is a diagram illustrating still another exemplary manner in which the recording sampling frequency is varied 
in accordance with the waveform data compressing method of the present invention; and 
Fig. 25 is a diagram illustrating a manner in which an original pitch is varied in accordance with the waveform data 
40 compressing method of the present invention. 

Fig. 1 is a block diagram illustrating a structural example of a tone generating device 1 9 used to implement a tone 
generating method of the present invention. 

The tone generating device 19 in Fig. 1 comprises: an arithmetic processing unit (CPU) 1 which executes an appli- 

45 cation program or the like to perform various control, arithmetical formation of tone waveform samples, etc. ; a read-only 
memory (ROM) 2 having stored therein an operating program for the CPU 1 , preset tone color data and the like; a ran- 
dom-access memory (RAM) 3 having a working memory area for the CPU 1 and storage'areas for tone color data etc.; 
a timer 4 for keeping time and indicating timer interrupt timing to the CPU 1 ; a MIDI interface 5 via which a MIDI event 
is input to the device 19 and a generated MIDI event is output from the device 19; and a keyboard 6, similar to that of 

so an ordinary personal computer, having keys of English and Japanese alphabets, numerals, marks, etc. As well known 
in the art, "MIDI" is an acronym of musical instrument digital interface. 

The tone generating device 19 further comprises: a cfisplay (monitor) 7 via which a user is allowed to dialog with 
the device 19; a hard disk (HDD) 8 which has installed therein application programs such as a program for generating 
tones and also has recorded therein tone waveform data to be used to arithmetically form tone waveform samples; a 

ss reproduction section (DMA: Direct Memory Access) 9 which, without intervention of the CPU 1 . permits direct transfer 
of tone waveform sample data to or from one of the areas of RAM 3 designated by the CPU 1 ; a digital-to-analog (D/A) 
converter (DAC) 10 for converting tone waveform sample data into analog tone signals; and a sound system 1 1 includ- 
ing amplifiers and speakers for audibly reproducing or sounding the analog tone signals supplied from the D/A con- 
verter 10. 
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In the hard disk 8, there may be stored various other data such as automatic performance data and chord progres- 
sion data and the above-mentioned operating program. By prestoring the operating program in the hard disk 8 rather 
than in the ROM 2 and loading the operating program into the RAM 3, the CPU 1 can operate in exactly the same way 
as where the operating program is stored in the ROM 2. This greatly facilitates version-up of the operation program, 

5 addition of an operating program, etc. A CD-ROM (compact disk) 13 may be used as a removably-attachable external 
recording medium for recording various data such as automatic performance data, chord progression data and tone 
waveform data and an optional operating program. Such an operating program and data stored in the CD-ROM 13 can 
be read out by a CD-ROM drive 14 to be transferred for storage into the hard disk 8. This facilitates installation and ver- 
sion-up of the operating program. The removably-attachable external recording medium may be other than the CD- 

10 ROM, such as a floppy disk and magneto optical disk (MO). 

A communication interface 1 5 may be connected to a bus 1 2 so that the device 1 9 can be connected via the inter- 
face 15 to a communication network 16 such as a LAN (local area network), internet and telephone line network and 
can also be connected to an appropriate sever computer 1 7 via the communication network 16. Thus, where the oper- 
ating program and various data are not contained in the hard disk 8, these operating program and data can be received 

is from the server computer 1 7 and downloaded into the hard disk 8. In such a case, the tone generating device 1 9, a "cli- 
ent", sends a command requesting the server computer 1 7 to download the operating program and various data by way 
of the communication interface 15 and communication network 16. In response to the command, the server computer 
1 7 delivers the requested operating program and data to the tone generating device 1 9 via the communication network 
1 6. The tone generating device 1 9 completes the necessary downloading by receiving the operating program and data 

20 via the communication network 1 5 and storing these into the hard disk 8. 

It should be understood here that the tone generating device 19 may be implemented by installing the operating 
program and various data corresponding to the present invention in a commercially available personal computer. In 
such a case, the operating program and various data corresponding to the present invention may be provided to users 
in a recorded form on a recording medium, such as a CD-ROM or floppy disk, which is readable by the personal com- 

25 puter. Where the personal computer is connected to a communication network such as a LAN, the operating program 
and various data may be supplied to the personal computer via the communication network similarly to the above-men- 
tioned. 

Figs. 2 to 5 illustrate various register areas that are provided in the RAM 3, of which Fig. 2 illustrates areas where 
are stored various data and waveform data, Fig. 3 illustrates an input buffer where are stored MIDI messages input via 
30 the MIDI interface 5, and Fig. 4 illustrates a tone generator register area where are stored various parameters neces- 
sary for generating tone waveform samples of a plurality of channels. In the area of Fig. 2, there are stored 1 6 kinds of 
tone color data "PD1 , PD2 PD16" and n kinds of waveform data "WD1 , WD2, ... WDn". OPEG (original pitch enve- 
lope) waveforms to be later described are stored along with the waveform data "WD1 , wD2, ... WDrf in corresponding 
relations thereto. 

35 Each of the tone color data is comprised of data designating a waveform of a given pitch range (pitch range wave- 
form designating data); data for controlling a low frequency oscillator (LFO) to be used for imparting vibrato effect or the 
like (LFO controlling data OD); data for controlling generation of a filter envelope to time-vary a tone color filter charac- 
teristic (FEG controlling data OD); data for controlling generation of a tone volume envelope to control a tone volume 
variation characteristic (AEQ controlling data OD); touch controlling data for varying a rising speed of tone or the like in 

40 accordance with a detected key-touch velocity (touch controlling data OD) ; and other data including waveform-sample- 
forming-resolution controlling data (other data OD). "OD" attached at the end of each of the above-mentioned data 
stands for "original data" before being subjected to control such as modulation. 

In the input buffer area of Fig. 3, MIDI event data ID1 , ID2, ID3 indicative of various events such as note-on and 

note-off events and input via the MIDI interface 5 are sequentially written. By reading out these MIDI event data ID1 , 

45 ID2, ID3, .... an event process is performed in the tone generating device so as to form tone waveform samples corre- 
sponding to the read-out MIDI event data. Each of the MIDI event data ID1 , ID2, ID3, ... is comprised of data indicative 
of the contents of the MIDI event and time at which the event data occurred (data occurrence time or event occurrence 
time). The data occurrence time can be determined by reading current time kept by the timer 4 when the MIDI event 
data is received. 

so The area shown in Fig. 4 is used as the tone generator register area comprised of registers provided tor a plurality 
of tone generating channels (in this example, 32 channels CH1 to CH32), and each of the registers has stored therein 
various tone parameters for controlling a tone waveform sample to be formed in the corresponding tone generating 
channel. In each of the registers (channel registers), there are stored a note number of a tone to be formed in the cor- 
responding channel, data designating any of the waveform data stored in the RAM 3 (waveform designating data D), 

55 LFO controlling data D, filter envelope controlling data (FEG controlling data D), tone volume envelope controlling data 
(AEG controlling data D), note-on data and other data D. Each of the channel registers also includes a working area to 
be used during arithmetical formation of a tone sample in the corresponding tone generating channel. "D" attached at 
the end of each of the above-mentioned data is an abbreviation of data and represents data already channel-assigned 
for sounding of a tone, as distinguished from the above-mentioned original data (OD). 
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The waveform designating data D, LFO controlling data D, FEG controlling data D and AEG controlling data D of 
each of the tone generating channels are tone forming data obtained by processing any of the tone color data PD1, 
PD2, PD3, ... PD1S on the basis of the contents of the MIDI event. 

Fig. 5 illustrates an output buffer area provided in the RAM 3. Because, in the tone generating method of the 

5 present invention, the number of tone waveform samples to be collectively arithmetically formed upon arrival of each 
calculating time is caused to change by a variation of the waveform sample forming resolution CC (whose concept has 
already been discussed at the outset of this specification), there are provided a plurality of output buffers in correspond- 
ing relations to a plurality of waveform sample forming resolutions CC. Namely, in the preferred embodiment of the 
present invention, as shown in Figs. 5A to 5C, three different waveform sample forming resolutions are employed and 

w there are provided three output buffers: output buffer BO for a basic waveform sample forming resolution (CC = 0: equiv- 
alent sampling frequency of 48 kHz); output buffer B1 for 1/2 of the basic waveform sample forming resolution (CC = 1 : 
equivalent sampling frequency of 24 kHz); and output buffer B2 for 1/4 of the basic waveform sample forming resolution 
(CC = 2: equivalent sampling frequency of 1 2 kHz). Accordingly, output buffer B1 has a capacity to store 1/2 of the sam- 
ples to be stored in buffer BO, and output buffer B2 has a capacity to store 1/4 of the samples to be stored in output 

is buffer BO. 

The waveform sample forming resolution CC is designated both for each of the tone generating channels and for 
each tone waveform being sounded, and the waveform sample forming resolution CC specifies the number of tone 
waveform samples to be arithmetically formed in the corresponding channel. Thus, the waveform sample forming res- 
olution CC can be expressed in an equivalent sampling frequency corresponding to the number of tone waveform sam- 

20 pies to be formed. One of the three waveform sample forming resolution CC is selected depending on a frequency band 
covered by tone waveform samples to be formed. 

Output buffer BO shown in Fig. 5A is used where tone waveform samples to be formed are of a wide frequency 
band, and it stores 128 tone waveform samples (SD1, SD2, SD3, ... SD128) formed at each predetermined calculating 
time point. Output buffer B1 shown in Fig. 5B is used where tone waveform samples to be formed are of a less wide 

25 frequency band, and it stores 64 tone waveform samples (SD1 , SD2, SD3, ... SD64) formed at each predetermined cal- 
culating time point. Output buffer B2 shown in Fig. 5C is used where tone waveform samples to be formed are of a nar- 
row frequency band, and rt stores 42 tone waveform samples (SD1 , SD2, SD3, ... SD32) formed at each predetermined 
calculating time point. 

In each of these buffers BO to B2. there are additively stored tone waveform samples of various channels having 
30 been formed with a same waveform sample forming resolution CC (i.e., in such a manner to cover substantially the 
same frequency band), rather than on a channel-by-channel basis. That is, each newly formed tone waveform sample 
is added to already stored tone waveform samples in one of the output buffers and then stored into a same location of 
the buffer. 

Once formation of tone waveform samples has been completed for all the tone generating channels, these wave- 

35 form samples are accumulated and passed to the reproduction section 9 for audible reproduction. However, because 
different numbers of tone waveform samples are stored in buffer BO, buffer B1 and buffer B2, the samples can not be 
accumulated in a simple manner. 

That is, an interpolation is effected between every adjacent ones of the 64 tone waveform samples stored in buffer 
B1 so as to provide 128 tone waveform samples that are then stored in buffer BV shown in Fig. 5D, and similarly an 

40 interpolation is effected between every adjacent ones of the 32 tone waveform samples stored in buffer B2 so as to pro- 
vide 128 tone waveform samples to be stored in buffer B2' shown in Fig. 5E. In this case, every other tone waveform 
sample in buffer BV will have the same value as one of the 64 tone waveform samples at a corresponding location in 
buffer B1 , and every fourth tone waveform sample in buffer B2' will have the same value as one of the 32 tone waveform 
samples at a corresponding location in buffer B2. 

45 Then, the tone waveform samples at each corresponding location of buffers BO, BV and B2' now containing 128 
samples are accumulated and stored into, for example, the corresponding location of the buffer BO. After that, the accu- 
mulated waveform samples in the buffer BO are reserved for reproduction so that the samples are later read-out by the 
reproduction section 9 for audible reduction via the sound system. The tone waveform samples of all the channels need 
not necessarily be stored in the buffer BO, and may be stored in any other output buffer having a storage area for 128 

so samples. 

With reference to Figs. 6 to 1 1 , the tone generating method of the present invention will be outlined which is irrple- 
merrted in the tone generating device of Fig. 1 by use of the output buffers as mentioned earlier. In this preferred embod- 
iment, the tone generating device 19 employs a tone generator based on the known waveform memory method 
(waveform-memory-based tone generator). Ftg. 6 illustrates an example of waveform data from the start to end of a 
55 tone which are stored in the buffer (i.e.. a set of waveform data to be used for complete (start-to-end) sounding of a 
tone); Figs. 7A to 7D illustrate frequency spectra extracted at various time points of the waveform data of Fig. 6 ; Fig. 8 
illustrates an exemplary time-variation of pitch in a waveform from the start-to-end of a tone when the arithmetically 
formed tone waveform samples are reproduced at a fixed reproducing rate; Fig. 9 illustrates an exemplary variation of 
waveform sample forming resolution CC in relation to the sample calculating time; Fig. 10 illustrates an exemplary man- 
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ner in which F number is varied over time for arithmetically forming waveform samples of a tone; and Fig. 11 is a timing 
chart explanatory of tone generator processing to form a tone waveform. 

According to the tone generating method of the present invention, as shown in item (a) of Fig. 1 1 , tone waveform 
samples are arithmetically formed for a predetermined unit section to be read out from the reproduction section 9 when- 

5 ever the calculating time points T1 , T2, T3, T4 ... arrives. New note-on and/or note-off event are received between the 
calculating time points as shown in item (b) of Fig. 1 1 , and a plurality of tone waveform samples corresponding to these 
events are arithmetically formed collectively at timing as shown in item (c) of Fig. 1 1 . 

Thus, the arithmetically formed tone waveform samples of all the tone generating channels stored in the output 
buffer BO are read out by the reproduction section 9 as waveform samples for the unit section so that they are repro- 

10 duced at a constant reproducing rate (i.e., at a fixed reproducing sampling frequency). 

As described earlier in relation to the output buffers, when a plurality of tone waveform samples for a single unit sec- 
tion are to be arithmetically formed in the present invention, the waveform sample forming resolution CC in the system 
is changed to one corresponding to a frequency band of a tone waveform to be formed as will be described below. 
Horizontally elongate band WS in Fig. 6 represents a group of multiple waveform data contained in a decay tone 

is with the horizontal axis representing passage of time, and for a purpose of illustration, the waveform data at time points 
"a", V, "c" and "d" are extracted and shown emphatically by oblique hatching in the figure. In Figs. 7A to 7D, there are 
shown examples of spectral distribution of fundamental and harmonic waves contained in the waveform data at these 
time points "a", "b", "c" and "d". More specifically, the section at time point "a" is an attack portion whose exemplary 
waveform shape is shown in detail in Fig. 6 and which contains a lot of harmonic wave spectral components as shown 

20 in Fig. 7A. The section at time point "b" is where high-frequency harmonic wave spectral components have slightly 
attenuated as shown in item Fig. 7B. 

The section at time point "c" is a sustain portion where attenuation has further progressed as seen from its exem- 
plary waveform shape in Fig. 6. As shown in Fig. 7C, the waveform at time point "c" is a simple waveform, close to that 
of the fundamental wave, with high-frequency harmonic wave components even further attenuated. Finally, the section 

25 at time point "d" is where high-frequency harmonic spectral components have virtually completely attenuated to null, 
leaving only the fundamental wave. 

Because the frequency band of waveform data of a generated tone varies over time, there arises the problem that 
arithmetic formation of waveform data is performed even for unnecessary frequency bands as long as there is employed 
such a fixed waveform sample forming resolution as enabling formation of waveform data of a widest possible fre- 

30 quency band of the tone. 

To avoid this inconvenience, the tone generating method of the invention is characterized by varying the waveform 
sample forming resolution CC in response to passage of time during arithmetical formation of a tone as shown in Fig. 
9. In the illustrated example, the waveform sample forming resolution CC is set initially to the basic value of 48 kHz till 
time point t2, then to 24 kHz, i.e., half the basic value, between time points t2 and t4, and then to 1 2 kHz, half the second 

35 value, after time point t4. Such a variation in the waveform sample forming resolution CC is made only once at the 
beginning of each unit section of Fig. 1 1 , with no waveform sample forming resolution variation taking place at an inter- 
mediate point of the unit section. 

By applying a different waveform sample forming resolution CC depending on the time-varying frequency band, the 
present invention effectively prevents waveform data formation from being performed for unnecessary frequency bands 

40 to thereby save wasteful calculations. Allocating the time for the saved calculations to another tone generating channel 
can enhance the quality of a tone generated in that channel and can also provide an increased number of the channels 
capable of simultaneously generating tones. 

According to a modification of the present invention, the waveform sample forming resolution in each tone gener- 
ating channel may be varied at an intermediate point in a unit section. In such a case, arithmetic formation of waveform 

45 data in the channel is changed in response to the varied waveform sample forming resolution CC and the output buffer 
for accumulating output data of the channel is changed at an intermediate point in the unit section. 

Incidentally, because the waveform data WD1 , WD2, ... WDn stored in the RAM 3 shown in Fig. 2 vary in frequency 
band during formation of a corresponding tone as noted earlier, the present invention, in response to the frequency 
band variation, varies the recording sampling frequency at which waveform data is sampled for storage, to thereby 

so reduce the amount of waveform data to be stored. In this connection, it is customary in the art that the sampling fre- 
quency is made high for the attack section and gradually lowered in accordance with attenuation of the waveform data. 
If the waveform data stored with the sampling frequency varied consecutively during formation of a corresponding tone 
in the above-mentioned manner are read out from the RAM 3 at a fixed rate, the waveform data will cause a variation 
in pitch in accordance with the sampling frequency. 

55 In the respective one-period waveforms at time points "a" and V in Fig. 6, the waveform width (along the horizontal 
axis) at time point "c" is decreased to one half of that at time point "a" due to the above-noted sampling frequency var- 
iation in the generated tone. Namely, although the waveform at time points "a" and "c" were originally of the same pitch, 
the length of an address region in the waveform memory where the one-period waveform at time "c" is stored is 
decreased to about a half of that for time point "a" because the sampling frequency in recording the waveform at time 
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point "c" was about a half of that at time point "a". 

An exemplary waveform (OPEG) in Fig. 8 shows a variation of original pitch (OP), during formation of a tone, when 
the waveform data are read out by use of the basic waveform sample forming resolution (48 kHz in the example of Fig. 
9). In the illustrated example of Fig. 8, the original pitch OP of note number C2 linearly changes, from time point t1 to 

5 time point t3, to the pitch of note number C3 which is one octave higher than that of C2; the vertical axis represents a 
cent scale. Thus, when such waveform data are read out to form tone samples, it is necessary to control the readout 
rate (F number, i.e., a rate at which the read address advances in the waveform memory per sample of a tone to be 
formed) in such a manner that no pitch variation occurs during generation of the tone. "OP" stands for an original pitch, 
and "OPEQ" stands for an original pitch envelope. 

w Here, the sampling frequency at which waveform data is sampled to be stored into the waveform memory presents 
an exactly opposite variation (along the cent scale) to that of the above-mentioned OPEQ waveform, and OPEG control 
data for controlling the shape of the OPEG waveform is generated on the basis of the data that controlled the sampling 
frequency variation during recording. 

In order to generate a tone of a designated pitch, it suffices to, on the basis of the designated pitch and OPEG 

is waveform) generate an F number as a pitch variation amount for shifting the original pitch (indicated by the values of 
the OPEG waveform). Specifically, a difference between the designated sounding pitch and original pitch is calculated 
in cents. Then, the calculated difference is converted from the cent representation into Hz representation so as to deter- 
mine an F number. In this case, once the OPEG varies, the F number varies with the OPEG variation, even when there 
is no variation in the designated sounding pitch. 

20 A predetermined number of waveform samples specified by the waveform sample forming resolution CC are arith- 
metically formed, at each calculating time, as samples for a single unit section. However, when the waveform sample 
forming resolution CC varies during formation of a tone as shown in Fig. 9. it is necessary to simultaneously change the 
readout rate (F number) at which the waveform data are read out per sample to be formed. If, for example, the basic 
waveform sample forming resolution (CC = 0) of 48 kHz is halved to 24 kHz (CC = 1). the waveform readout rate per 

25 sample has to be increased twice as high as the original, and if it is lowered to 12 kHz (CC = 2), the waveform readout 
rate per sample has to be increased four times as high as the original. 

For this reason, the present invention is constructed to change, simultaneously with the variation of the waveform 
sample forming resolution, the F number, i.e., an amount of per-sample increment of an address counter for reading out 
waveform data that is designated at the time of the arithmetic formation. The waveform sample forming resolution is set 

30 for each of the tone generating channels so as to minimize the amount of wasteful waveform calculations for the chan- 
nel. 

The present invention implements both waveform compression by variation in the waveform data sampling fre- 
quency (variation in the OPEG waveform shown in Fig. 8) and saving of the waveform calculations by variation in the 
waveform sample forming resolution CC (variation in the waveform sample forming resolution CC shown in Fig. 9), and 

35 as a result, the F number varies during generation of a tone in amanner shown in Fig. 10. As shown in Fig. 10, the F 
number having an initial value FNO is decreased in an arcuate curve from time point t1 to time point t2 in response to 
the OPEG waveform variation. The F number is doubled at time point t2 in response to the waveform sample forming 
resolution CC having been halved to 24 kHz, and then again decreased in an arcuate curve from time point t2 to time 
point t3 in response to the OPEG waveform variation. The F number is maintained at value FNO from time point t3 to 

40 time point t4 (i.e., the original F number is restored by the doubled OPEG waveform and the halved waveform sample 
forming resolution CC offsetting each other) and then further doubled at time point t4 in response to the waveform sam- 
ple forming resolution CC having been lowered to 1/4 of the original. After time point t4, the F number is maintained at 
value 2FN0. 

An equation to calculate the F number is: 

F number = 2 (SP " OP)/1200 • 2 <* Equation (1) 

, where SP represents a pitch of a note number to be sounded, OP an original pitch, and CC a ratio relative to the basic 
waveform sample forming resolution (48 kHz). When the basic waveform sample forming resolution is applied, CC = 0; 
50 when the waveform sample forming resolution is halved, CC = 1 ; and when the waveform sample forming resolution is 
lowered to 1/4, CC = 2. 

Fig. 12 is a flowchart of a main routine performed, by the CPU 1 of Fig. 1 , in a software tone generator implement- 
ing the tone generating method of the present invention. Upon a start of the main routine, initialization is performed at 
step S10, where all the tone generating channels are cleared and initial preparations are made of tone color data wave- 
55 form data, etc. 

At next step S20, a determination is made as to whether there is any received data, by ascertaining whether any 
MIDI received data has been recorded in the above-mentioned input buffer of Fig. 3. If there is no received data 
recorded in the input buffer, the CPU moves to step S40, but if there is any received data recorded in the input buffer, 
the CPU branches to step S30, where received data processing is executed for operations corresponding to the 
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received MIDI event (note-on process, note-off process and the like) and other necessary operations. 

It is checked at step S40 whether any switch has been activated. If answered in the negative at step S40, the CPU 
1 goes to step S60; if any switch has been activated, it is determined that there is a switch event, so that switch event 
process is executed at step S50 to set a tone color of one of plural performance parts as dictated by the activated 
5 switch. 

Then, tone generator processing is executed at step S60 to arithmetically form tone waveform samples collectively 
upon arrival of each calculating time. After performing other necessary processes at step S70, the CPU 1 loops back 
to step S20 to repeat the operations of steps S20 to S70 (regular loop). If the reproduction section 9 comprises a ded- 
icated tone generator based on selectable algorithms or a DSP tone generator, the tone generator processing at step 
w S60 may be omitted. 

Fig. 13 is a flowchart of a MIDI reception interrupt process carried out by the CPU 1. This MIDI reception interrupt 
process is activated when the MIDI interface 5 receives a MIDI event from the outside, with priority over other proc- 
esses. Upon a start of the MIDI reception interrupt process, the received data is loaded at step S80, and at step S90 it 
is written into the input buffer along with its time data (indicative of the time of reception of the received data) in a format 
is as shown in Fig. 3. After step S90, the CPU 1 returns to the process that was being executed just before the interrupt 
process. With these operations, MIDI data will be sequentially written into the input buffer along with the corresponding 
reception time data. 

Further, Fig. 14 is a flowchart of a tone color selection event process for part 1 that is executed as an example of 
the switch event processing at step S50 of the main routine, where for each of the performance parts, a tone color 
20 number selected by activation of a predetermined switch is stored as TC 1 at step S1 00. After the operation of step S1 00 
is completed for all the performance parts, the tone color setting process comes to an end. 

In Figs. 15A and 15B, there are shown details of the note-on process and note-off process, respectively, that are 
performed in the received data processing at step S30 of the main routine. 

When the received data is note-on event data, the note-on process is executed as shown in Rg. 15 A, where at step 
25 S1 10, the note number, velocity and part-specific tone color of the note-on event data stored in the input buffer are 
loaded into corresponding registers as NN, VEL and TC, respectively, and the occurrence time of the note-on event is 
also loaded into a corresponding register as TM. At next step S120, a channel assignment process is performed to 
assign the loaded note number NN to one of channels and the number V of the assigned channel is stored into a reg- 
ister. 

30 Then, at step S1 30, tone color data TP(TC) of the tone color TC now set for the individual performance part is proc- 
essed in accordance with the note number NN and velocity VEL Here, the tone color data is one selected from among 
tone color data PD1 to PD16 shown in Rg. 2. At next step S140, the processed tone color data including a pitch SP to 
be sounded is written into the tone generator register of channel number V of Rg. 4 along with the occurrence time TM 
of the note-on event Also, waveform designating data D to be written into the tone generator register is determined by 

35* using the note number NN to refer to the pitch range waveform designating data of the tone-color data shown in Fig. 2, 
and any one of the waveform data WD1 to WDn is designated as a waveform to be used for forming a tone correspond- 
ing to the note number NN. 

Then, at step S1 50, timing to vary the waveform sample forming resolution of the Y channel and forming resolution 
control data designating a waveform sample forming resolution value are set into the T channel tone generator register. 

40 The setting of such forming resolution control data is effected on the basis of forming resolution control data contained 
in the tone color data selected for the Y channel. Because the timing to vary the waveform sample forming resolution 
is specified once for each unit section where calculations take place per calculating time, the waveform sample forming 
resolution variation can be achieved by detecting the number of arrivals of the calculating time. Then, at step S160, 
OPEG control data read out from a waveform data area is set into the Y channel tone generator register. The OPEG 

45 control data is data for controlling the shape of the OPEG waveform that represents a manner in which the original pitch 
varies during generation of a tone as shown in Fig. 8. 

Note-on data is written into the tone generator register of the Y channel at next step S1 70, and then the note-on 
event process comes to an end. 

When the received data is note-off event data, the note-off process is executed as shown in Fig. 1 5B, where at step 

so S180, the note number, velocity and part-specific tone color of the note-off event data stored in the input buffer are 
loaded into corresponcfing registers as NN, VEL and TC, respectively, and the occurrence time of the note-off event is 
also loaded into a corresponding register as TM. Then, at step S190, one of the tone generating channels is identified 
which is generating a tone of the tone color TC and note number NN, and the identified channel number Y is stored 
into a register. 

55 The occurrence time TM and note-off data are written into the Y channel tone generator register at step S200, and 
then the note-off process comes to an end. 

Now, with reference to Fig. 16, a fuller description is made about the tone generator processing that is executed at 
step S60 in the regular loop of the main routine. 

First, at step S21 0, the tone generator registers are checked to see whether any new data has been written therein. 
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The CPU 1 proceeds directly to step S250 if no new data has been written; if some new data has been written, the CPU 
1 branches to step S230, where the written data is converted into control data for controlling waveform formation. 

Then, predetermined preparations for calculations are made on the basis of the converted control data at step 
S240, such as tone generator controlling preparations, e.g., of note-on/note-off, pitch bend, EXP, pan and other data 

s and creation of sets of control time and control data. That is, each time new data is written, the predetermined prepa- 
rations are made at steps S230 and S240 for subsequent tone forming calculations at steps S270 to S290. 

At next step $250, in such a manner that readout of waveform data is not broken off in the reproduction section 9, 
a calculating time management process is performed to designate a predetermined time point before current reproduc- 
tion of waveform data comes to an end. More specifically, in arithmetically forming a plurality of tone waveform samples 

w corresponding to a single unit section as shown in item (c) of Fig. 1 1 at each calculating time as shown in item (a), the 
calculating time management process is performed to set the calculating time point in consideration of the time required 
for the arithmetic formation, so as to prevent an undesirable break in the waveform samples read out by the reproduc- 
tion section 9. 

Then, at step S260, a determination is made as to whether a calculating time point set via the above-mentioned 

is calculating time management process has arrived. H answered in the negative at step S260, the CPU 1 terminates the 
tone generator processing without doing other processes, tf no new data has been written in the tone generator register 
and the set calculating time point has not arrived, no particular operations are performed in the tone generator process- 
ing. Once the set calculating time point has arrived after stepping through the regular loop of the main routine several 
times, a process is executed, at and after step S270, to arithmetically form a plurality of tone waveform samples corre- 

20 sponding to a single unit section. 

That is, at step S270, various channel control processing is performed in accordance with tones to be generated in 
the individual channels, such as a forming resolution varying process for designating a specific number of tone wave- 
form samples to be formed per unit time; a calculating order determining process to determine a calculating order 
across the channels in such a manner that necessary calculations are performed from one of the channels sounding a 

25 most important tone to another channel sounding a least important tone; and a tone-deadening channel (channel to be 
muffled) determining process for determining the last channel in the calculating order as a channel where the currently 
sounding tone should be deadened or muffled. 

A control data unfolding process is executed at next step S280, where the data prepared at the above-mentioned 
step 8240 is unfolded along the time axis to make preparations for the calculations. After that a waveform forming cal- 

30 culation process is executed, where reproductive waveform data (tone waveform samples) for a single unit section are 
calculated on the basis of the data unfolded at step S290. In addition, as described earlier in relation to Fig. 5, repro- 
ductive waveform data of different waveform sample forming resolutions are subjected to interpolation in such a manner 
to be identical in number to those formed with the basic waveform sample forming resolution, and then the reproductive 
waveform data of all the channels are accumulated to be stored, for example, into the buffer BO. Then, at step S300, a 

35 reproduction reservation is made, with respect to the buffer BO storing the accumulated reproductive waveform data 
from all the channels, such that the reproduction section 9 later reads out the reproductive waveform data. 

As described above, the present invention can vary the waveform sample forming resolution individually for each 
of the tone generating channels and during formation of a tone in the channel. Fig. 1 7 is a flowchart illustrating a detail 
of the channel control processing executed at step S270 of the tone generator processing. 

40 In the channel control processing, the waveform sample forming resolution varying process is executed at step 
S31 0 to vary the waveform sample forming resolution during formation of a tone on the basis of forming resolution con- 
trol data supplied to each of the channels. In this control process, passage of time is counted to control timing for vary- 
ing the waveform sample forming resolution. If there is currently no need to vary the waveform sample forming 
resolution, the CPU 1 goes directly to step S340; however, if there is any channel where the waveform sample forming 

45 resolution has to be varied (i.e., when there has arrived the variation timing designated by the forming resolution control 
data of the channel), an affirmative determination results at step S320, so that the waveform sample forming resolution 
CC of the channel is changed to a new value (a value at the timing designated by the control data) at step S330. " 

At step S340, the calculating order determining process is executed to determine a calculating order across a plu- 
rality of the tone generating channels in such a manner that necessary calculations for those channels sounding impor- 

50 tant tones or tones that should not be deadened are performed with priority over the other channels. Here, such 
channels that are not currently sounding tones do not need calculations and hence do not have to be included in the 
calculating order. Then, amounts of the calculations for all the channels are accumulated at step S350 to determine a 
total calculation amount In this case, the respective calculation amounts of the individual channels differ due to different 
waveform sample forming resolutions applied to the channels and also the tone generating method if different types of 

55 the tone generating method are employed in the channels. At next step S360, a determination is made as to whether 
the determined total calculation amount is excessive or exceeds a predetermined range. If the total calculation amount 
is within the predetermined range, the CPU 1 terminates the channel control processing without performing any other 
operations, so as to execute the waveform calculating process as will be described in detail later. 

If it is determined at step S360 that the total calculation amount exceeds the predetermined range, this means that 



2/10/05, EAST Version: 2.0.1.4 



EP0 750 290 A2 



necessary calculations will not be completed before predetermined readout timing of the reproduction section 9 and 
there will be a break in the reproductive waveform data. For this reason, the waveform sample forming resolution CC of 
each channel after a predetermined place in the calculating order is lowered by T (the resolution value is incremented 
by 1) so as to reduce the number of samples to be actually formed; that is. the waveform sample forming resolution CC 

5 = 0 is changed to the waveform sample forming resolution CC = 1 , and the waveform sample forming resolution CC = 
1 is changed to the waveform sample forming resolution CC = 2. 

After that, a determination is made at step S380 as to whether the total calculation amount is now within the pre- 
determined range. If the total calculation amount is within the predetermined range as determined at step S380, the 
channel control processing comes to an end; if, however, the total calculation amount is still more than the predeter- 

w mined range, one or more channels at or before the last place in the calculating order are determined as tone-deaden- 
ing or muffling channels and then the currently sounding tones are deadened in the determined channels. 

If the number of tones to be generated is excessive, it has been customary for the conventional tone generator con- 
trol technique to perform a so-called "truncate" process to compulsorily deaden any of tones being generated. In con- 
trast, the preferred embocGment of the invention attempts to avoid such a conventional tone deadening even when the 

is total calculation amount is determined at step S360 to exceed the predetermined range, by first lowering the waveform 
sample forming resolution through the operations of steps S370 to S390. Because the waveform sample forming reso- 
lution lowering is applied only to one or more tones of lower importance, no adverse musical effects will result However, 
only when it is determined that the excessive calculation amount can not be property dealt with by the lowering of the 
forming resolution alone, the preferred embodiment resorts to the conventional tone deadening process. 

20 Once the channel control processing is completed in the above-mentioned manner, the waveform calculating proc- 
ess is carried out as described hereinbelow. 

Fig. 18 is a flowchart illustrating a detail of the waveform calculating process. First, at step S400, necessary prep- 
arations are made with respect to the tone generating channel placed first in the calculating order, and the output buff- 
ers of Fig. 5 are all cleared prior to the calculations. At next step S410, an F number is generated using the above- 

25 mentioned Equation (1) on the basis of a sounding pitch SP, waveform sample forming resolution CC and original pitch 
OP. Because of the arrangement that an F number is generated for each of the channels in each execution of step 
S41 0, the F number can vary immediately in response to a variation of the waveform sample forming resolution CC and 
original pitch OP during formations of a tone. The F number can also vary in response to a variation of the pitch SP, 
caused by impartment of a pitch bend, vibrato or other effect, during formation of a tone. 

30 It is usually not necessary to vary the F number during tone waveform sample forming calculations for a single unit 
section, because the calculating time points normally occur at intervals of about several milliseconds. 

Then, at step S420, a read address is generated, so that waveform data is read out in accordance with the integer 
portion of the generated read address and an interpolation is performed between two successively read-out waveform 
data in accordance with the decimal portion of the read address. At next step S420, the above-mentioned generation 

35 of per-sampie read address and subsequent interpolation are repeated a predetermined number of times correspond- 
ing to the forming resolution CC, so as to form a predetermined number of interpolated samples corresponding to the 
forming resolution CC. The read address for each interpolated sample is obtained by adding the F number to the read 
address of the last interpolated sample. Thus, the read address increments, for each interpolated sample, at a rate cor- 
responding to the F number, and the pitch of the read-out waveform is controlled in accordance with the incrementing 

40 rate of the address. 

Then, at step S430, the interpolated sample generated at the preceding step is subjected to tone volume control 
based on a tone volume envelope waveform and then added into one of the buffers BO to B2 which corresponds to the 
current waveform sample forming resolution CC. The tone volume envelope waveform, which is a waveform for control- 
ling variation of the tone volume envelope from the attack to decay of a tone, is arithmetically formed in correspondence 
45 with individual interpolated samples on the basis of the AEG controlling data D stored in the tone generator register 
region for each channel. As described previously, both the number of interpolated samples to be formed and the 
" number of samples to be stored in a selected one of the output buffers-are controlled by the forming-resolution CC to 
be the same. Thus, the operation of step S430 is performed on a sample-by-sample basis similarly to the above-men- 
tioned step S420. That is, the tone volume control based on the tone volume envelope waveform and addition into the 
so output buffer are performed on a sample-by-sample basis. 

By executing the various processes in the above-mentioned sequence, it is possible to minimize the number of the 
CPU's write and read to and from calculating registers, to thereby increase the overall processing speed. 

In this way, tone waveform samples calculated in the channels employing the basic waveform sample forming res- 
olution are additively stored into the buffer BO, tone waveform samples calculated in the channels employing 1/2 of the 
55 basic waveform sample forming resolution are additively stored into the buffer B1 . and tone waveform samples calcu- 
lated in the channels employing 1/4 of the basic waveform sample forming resolution are additively stored into the buffer 
B2. 

Then, at step S440, a determination is made as to whether the calculations have been completed for all the tone 
generating channels requiring such calculations. If there is still any tone generating channel left requiring the calcula- 
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tions (i.e., still sounding a tone), the determination at step S440 becomes negative, so that the CPU 1 branches to step 
S4S0 to make the above-mentioned preparations for the next tone generating channel and thereafter reverts to step 
$41 o. Thus, the operations of steps S41 0 to $480 are repeated until the calculations are completed for all the tone gen- 
erating channels. 

5 When the CPU 1 are running another software program in parallel with the program of the invention, the necessary 
calculations may be delayed because too much time is spent on processing of the software, tn such a case, in order to 
avoid an undesirable break in the reproduction by the reproduction section 9, it may be determined at step S440 that 
the calculations have been completed for all the tone generating channels even though there is still any tone generating 
channel left requiring the calculations. 

10 As a result of the above-mentioned operations, interpolated samples of a plurality of the tone generating channels 
calculated according to the waveform sample forming resolution CC are accumulatively stored into the buffers BO, B1 
and B2 shown in Rg. 5. 

Once the calculations have been completed for all the tone generating channels requiring such calculations, inter- 
polation operations are performed at step S450 on the waveform samples stored in the buffer B1 (twofold oversampling) 

is so that the interpolated samples are caused to be identical in number to those calculated with the basic waveform sam- 
ple forming resolution and then stored into the buffer BV having the same construction as the buffer BO (see Fig. 5D). 
Then, interpolation operations are performed at step S460 on the waveform samples stored in the buffer B2 (fourfold 
oversampling) so that the interpolated samples are caused to be identical in number to those calculated with the basic 
waveform sample forming resolution and then stored into the buffer B2' having the same construction as the buffer BO 

20 (see Fig. 5E). 

Subsequently, by adding the waveform samples of the buffers B1 ' and B2' into the buffer BO, the waveform samples 
of all the channels are stored into the buffer BO (see Fig. 5F). This terminates the waveform calculating process, and 
the stored waveform samples in the buffer BO will then be reserved to be read out by the reproduction section 9 for audi- 
ble reproduction. 

25 The tone generating method of the present invention has been described above as a program executed by the tone 
generating device of Rg. 1 . but it may be executed as a single application program on a general-purpose computer 
operated by various operating systems such as "Windows" (operating system for personal computers commercially 
available from Microsoft Corporation, U.S.A.). 

Although a detailed description has not been made above about the calculation process for collectively forming a 

30 plurality of waveform samples per predetermined unit time, the calculation process may be other than mere waveform 
memory readout operations as in the foregoing embodiment such as the known FM synthesizing operations, AM syn- 
thesizing operations or Fourier synthesizing operations. 

With the above-described arrangements, the present invention can determine a waveform sample forming resolu- 
tion, for each tone generating channel, depending on whether or not a tone waveform to be sounded is of a wide fre- 

35 quency band; or on importance of the tone. The present invention can also arithmetically form tone waveform samples 
irrespective of whether a tone waveform to be sounded is of a wide frequency band or narrow frequency band, without 
performing wasteful calculations. 

Further, because the waveform sample forming resolution is raised for the attack portion of a decay tone in order 
to form a greater number of waveform samples and is lowered for the sustain portion to form a smaller number of wave- 

40 form samples, wasteful calculations can be avoided so that waveform samples from the start to end of a tone can be 
formed efficiently without involving wasteful calculations. 

By thus saving waveform calculations for a specific tone generating channel, it is possible to increase the amount 
of waveform calculations for another tone generating channel to thereby enhance the quality of a tone generated in that 
channel, and the number of channels capable of simultaneously generating tones can be increased. 

45 Moreover, because the invention can control the number of tone waveform samples to be formed per unit time inde- 
pendently for each channel, tones can be generated with different qualities among the channels. Also, it is allowed to 
reduce the amount of calculations for a specific channel which will present no significant effect even though the tone 
generated therein is of low quality. 

Next, with reference to Figs. 6, 7A to 7D and 19 to 25, a description will be made about a waveform data compress- 
so ing method according to another aspect of the present invention. 

As mentioned earlier, Rg. 6 diagrammatically shows a set of waveform data stored in a buffer to be used for com- 
plete (start-to-end) sounding of a single tone, Rgs. 7A to 7D illustrate frequency spectra of the waveform data of Fig. 6 
as extracted at various points "a", "b", V and "d", and Fig. 19 illustrates an exemplary manner in which sampling fre- 
quency Fs is varied when time-serial waveform data for complete sounding of a single tone are sampled and stored. 

55 First, with reference to Rgs. 6. 7A to 7D and 1 9, a description will be made about how the sampling frequency Fs 
is set. 

As shown in Rg. 7A, the waveform data of the attack portion at point "a" of Fig. 6, which has a relatively wide fre- 
quency band, present a frequency spectral distribution with numerous harmonic components existing up to high fre- 
quency F1 . The sampling frequency Fs in sampling the attack-portion waveform data of having the spectral distribution 
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shown in Fig. 7A has to be at least higher than frequency 2f1. 

The slightly attenuated waveform data at point V of Fig. 6 present a frequency spectral distribution with compo- 
nents existing up to frequency f2, as shown in Fig. 7B. That is, the higher-order harmonic components have attenuated 
faster, leaving the frequency band narrower than that of the attack portion. The sampling frequency Fs in sampling the 

5 waveform data of having the spectral distribution shown in Fig. 7B has to be at least higher than frequency 2f2. 

Further, the waveform data of a sustain portion at point "c", where the harmonic components have further attenu- 
ated, present a frequency spectral distribution with components existing only up to frequency f3 and has a considerably 
narrowed frequency band, as shown in Fig. 7C. The sampling frequency Fs in sampling the waveform data of having 
the spectral distrtoution shown in Fig. 7C has to be at least higher than 2f3; this means that the sampling frequency Fs 

to can be substantially lower than the above-mentioned sampling frequency 2f 1 for the attack portion. 

Also, as shown in Fig. 7D, the further attenuated waveform data at point "d" of Fig. 6, which only contain low-order 
harmonics, present a frequency spectral distribution with components existing only up to frequency f4 close to the fun- 
damental wave, leaving the frequency band far narrower than that of the attack portion. TTie sampling frequency Fs in 
sampling the waveform data of having the spectral distribution shown in Fig. 7D has to be at least higher than 2f4; this 

75 means that the sampling frequency Fs can be very low, e.g., several times lower than the above-mentioned sampling 
frequency 2f 1 for the attack portion. 

As mentioned, the sampling frequency necessary for the waveform data corresponding to complete (start-to-end) 
sounding of a single tone can be made lower as attenuation of the waveform data progresses. Thus, the present inven- 
tion is constructed to compress waveform data to be recorded, by varying the sampling frequency Fs in recording the 

20 waveform in the above-mentioned manner. 

In the illustrated example of Fig. 1 9, the sampling frequency Fs is set to an initial highest frequency of 48 kHz for a 
period up to time point t1 including at least a time when the attack portion ends, switched at time point t1 to a lower fre- 
quency of 32 kHz, and then again switched at time point t2 to 24 kHz that is half the frequency for the attack portion. 
Here, the per-unit-time waveform sample data amount from time point t1 to time point t2 is 2/3 of the initial per-unit-time 

25 waveform sample data amount prior to time point t1 , the per-unit-time waveform sample data amount from time point t2 
to time point t3 is 1/2 of the initial per-unit-time waveform sample data amount prior to time point t1 , and the per-unit- 
time waveform sample data amount from time point t3 is 1/4 of the initial per-unit-time waveform sample data amount 
prior to time point t1 . Thus, the amount of waveform samples for complete sounding of a single tone can be significantly 
reduced as a whole, and the waveform sample amount reduction will have greater effects when a multiplicity of wave- 

30 form data are sampled to be stored. 

The thus-reduced waveform sample data for complete sounding of the tone are directly written into the waveform 
memory, so that they will then be read out from the memory for audible reproduction at a fixed reproducing rate. The 
fixed reproducing rate is the converting timing of the D/A converter. However, if the waveform sample data for complete 
sounding of the tone are recorded while varying the sampling frequency Fs as shown in Fig. 19 and then reproduced 

35 at a fixed reproducing rate, the resultant rl^ sample data will naturally vary in pitch during generation" 

of the tone. 

Fig. 20 illustrates, as exemplary variations of original pitch OP, relationships between pitches detected when the 
waveform sample data are read out from the waveform memory and reproduced at a fixed reproducing rate of 48 k sam- 
ples per second and read addresses of the waveform memory. In Fig. 20, "NNO" represents a pitch of a note sounded 

40 at the time of recording, an address range before address Ad1 is one for reading out the waveform sample data formed 
up to time point t1 of Fig. 19. an address range from address Ad1 to address Ad2 is one for reading out the waveform 
sample data formed from time point t1 to time point t2 of Fig. 19, an address range from address Ad2 to address Ad3 
is one for reading out the waveform sample data formed from time point t2 to time point t3 of Fig. 19, and an address 
range after address Ad3 is one for reading out the waveform sample data formed after time point t3 of Fig. 19. 

45 What is shown in Fig. 20 is an instance where the fixed reproducing rate is 48 kHz equivalent to the highest sam- 
pling frequency Fs used during the waveform data recording, and because of the use of such a fixed reproducing rate, 
the waveform* sampte data read out from the addresses range before address Ad1 will have a pitch equivalent to the 
pitch NN0 of the note sounded at the time of recording. If one period of the waveform data at point "a" of Fig. 6 is equiv- 
alent to 100 samples, then the pitch will be 48 kHz - 100 = 480 Hz. The waveform sample data read out from the 

so address range from address Ad1 to address Ad2 will have a pitch that is 3/2 of the pitch NN0 because they are repro- 
duced at a fixed reproducing rate that is 3/2 of the rate used at the time of recording. Namely, the pitch will be 480 Hz 
-h (3/2) = 720 Hz. 

Further, the waveform sample data read out from the address range from address Ad2 to address Ad3 will have a 
pitch of 960 Hz that is twice as high as the pitch NNO because they are reproduced at a fixed reproducing rate that is 
ss twice as high as the rate used at the time of recording. That is, the pitch of the waveform sample data read out from the 
address range from address Ad2 to address Ad3 is one octave higher than the pitch NNO (NNO + 1 oct.). Similarly, the 
waveform sample data read out from the address range after Ad3 will have a pitch of 1 ,920 Hz that is 2 2 times as high 
as the pitch NNO because they are reproduced at a fixed reproducing rate that is 2 2 as high as the rate used at the time 
of recording. That is, the pitch of the waveform sample data read out from the address range after address Ad3 is two 
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octave higher than the pitch NNO (NNO + 2 Oct.). 

If waveform sample data are recorded with the sampling frequency Fs changed during formation of a tone as 
shown in Fig. 19 and the thus-recorded waveform sample data are reproduced at a fixed reproducing rate, the repro- 
duced waveform sample data will undesirably vary in pitch during sounding of the tone in a manner as shown in Fig. 20. 

5 Thus, it is necessary to control the sample data readout from the waveform memory so as to prevent the pitch variations 
of the reproduced waveform sample data. 

To this end, the pitch variation rate as shown in Fig. 20 is output, during recording of the waveform data, as original 
pitch variation control data to be used for generating F numbers, and the original pitch variation control data are stored 
in a control section of an electronic musical instrument as will be later described in detail. If in this case, the original 

10 pitch variation control data are data expressed in cents, a necessary pitch controlling process may be significantly sim- 
plified. The original pitch variation control data are control data to synthesize a variation curve of the original pitch OP 
as shown in Fig. 20. and in this case, they specify variation timing Ad1 . Ad2, ... and pitch values NNO, NN(720 Hz), NNO 
+ 1 oct 

Fig. 21 illustrates an exemplary manner in which the sampling frequency Fs is varied during recording of waveform 

is data for complete sounding of a single tone having a tone color that affords an effect of gradually increasing brightness. 
In the illustrated example, the waveform data have highest harmonic components for a period from time point t2 to 
time point t3 ( and in this period, the sampling frequency Fs is maintained at the highest 48 kHz. The sampling frequency 
Fs is set to 1 2 kHz for a period from the sounding start point to time point t1 , then set to 24 kHz for a period from time 
point t1 to time point t2, and restored to 24 kHz after time point t3. 

20 If waveform sample data are recorded with the sampling frequency Fs changed at intermediate points of a tone and 
the thus-recorded waveform sample data are reproduced at a fixed reproducing rate, the pitch of the reproduced wave- 
form sample data will undesirably differ from the recording pitch as mentioned above. Thus, also in this case, the pitch 
variation rate of the tone different in form from the foregoing is output, during recording of the waveform data, as original 
pitch variation control data to be used for generating F numbers, and the original pitch variation control data are stored 

25 in the control section of the electronic musical instrument. 

Fig. 22 is a block diagram illustrating an exemplary arrangement for effecting waveform preparations to record, into 
the waveform memory, waveform data that are sampled while varying the recording sampling frequency Fs. 

In the illustrated example, waveform data introduced via a waveform input section 20 such as a microphone are 
converted into digital signal by an A/D converter 21. Specifically, in this example, the A/D converter 21 samples the 

30 introduced analog waveform data with a fixed highest sampling frequency Fs (e.g., 48 kHz) and converts them into dig- 
ital waveform sample data. The original waveform sample data converted by the A/D converter 21 into digital represen- 
tation with the fixed sampling frequency Fs are written into an original waveform memory 23 by means of a memory 
write circuit 22. 

Then, the original waveform sample data are read out from the original waveform memory 23 and the sampling fre- 
M ""'xjuency is varied by a sampling frequency varying section 24. Namely, in the sampling frequency varying section 24, the 
waveform sample data are resampled in such a manner to lower the sampling frequency Fs, after limiting the frequency 
band via a low-pass filter (LPF) so that occurrence of aliasing noise is effectively avoided even though the frequency Fs 
is lowered. 

The variation of the sampling frequency Fs during formation of a tone is effected in the sampling frequency varying 
40 section 24 in such a mode as shown in Figs. 19 and 21, and a mode of varying the sampling frequency Fs, i.e., how 
and at which timing of the waveform data the sampling frequency should be varied, is designated by a variation mode 
designating section 26. The waveform sample data, having been changed by the sampling frequency varying section 
24 to the sampling frequency designated by the variation mode designating section 26, are written into the waveform 
memory 25 which can be used directly in the electronic musical instrument according to the present embodiment. 
45 If the thus-written waveform sample data are reproduced at a fixed reproducing rate, the reproduced waveform 
sample data will undesirably cause variation in pitch during sounding of the tone. Because, as seen from Figs. 19 and 
20, the pitch varies in accordance with the designation by the variation mode designating section 26, there are gener- 
ated original pitch variation control data corresponding to the designation by the designating section 26. The original 
pitch variation control data comprise variation values in cents and preset in the electronic musical instrument or wave- 
so form reproducing device that reads out the waveform sample data from the waveform memory 25 for reproduction. 

Fig. 23 is a block diagram illustrating a general structure of the electronic musical instrument including the wave- 
form memory in which waveform data are recorded in compressed form according to the waveform data compressing 
method of the present invention. For simplicity of description, the electronic musical instrument is assumed to generate 
a single tone at a time. 

55 In the illustrated example, the electronic musical instrument comprises: a keyboard (KB) 31 operated by a human 
player; a detection circuit 32 for detecting a note-on event(NON) and note number (NN) in cents of an operated or 
depressed key on the keyboard 33; a pitch envelope generator (pitch EG) 33 for, in response to passage of time from 
the occurrence of the note-on event NON detected by the detection circuit 32, generating a pitch envelope waveform 
AP expressed in cents to vary the pitch of a tone in accordance with a selected tone color number TC; and an adder 34 
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lor adding the pitch envelope waveform AP from the pitch envelope generator 33 to the note number NN detected by 
the detection circuit 32. 

The electronic musical instrument further comprises: an original pitch (OP) generator 37 for generating original 
pitch data OP on the basis of the above-mentioned original pitch variation control data expressed in cents; a subtracter 

s 35 for subtracting the generated original pitch data OP from the note number output from the adder 34 after having been 
added with the pitch envelope waveform (i.e., NN + AP); and a frequency number (FN) generator 36 for, in accordance 
with a modified note number from the subtracter 35 (i.e., NN + AP - OP ), generating a frequency number (FN) propor- 
tional to a pitch of a tone to be generated. Ttie original pitch generator 37 has stored therein a plurality of the original 
pitch variation control data corresponding to a plurality of waveform data to be stored in the waveform memory 39, and 

w the generator 37 generates the original pitch data OP by Lee of the original pitch variation control data corresponding 
to a waveform to be read out from the waveform memory 39 in response to the tone color number TC and note number 
NN. 

An address generator 38 selects a waveform from among those stored in the waveform memory in accordance with 
the tone color number TC and key range of the note number NN, and it outputs the start address of the selected wave- 
rs form as a first read address at the timing of the note-on ON event. Then, the address generator 38 increments the read 
address at a rate corresponding to a supplied F number. From the waveform memory 39 having stored therein the 
waveform data as compressed according to the waveform data compressing method of the present invention, waveform 
sample data MSD is read out in response to the integer portion of the read address generated by the address generator 
38. An interpolator! circuit 40 provides sample data ISD that is interpolated in response to the decimal portion of the 
20 generated read address using the waveform sample data successively read out from the waveform memory 39. Fur- 
ther, a multiplier 41 multiplies the interpolated sample data ISD from the interpolation circuit 40 by a tone volume enve- 
lope waveform AEG. The tone volume envelope waveform AEG indicates tone volume variations in the tone 
corresponding to the tone color number TC, and is generated by a tone volume envelope generator 42 in response to 
the timing of the note-on event NON. 
25 At a fixed reproducing rate, a D/A converter 43 converts into analog tone data the digital tone data (i.e., interpolated 
sample data ISD multiplied by the tone volume envelope waveform AEG) output from the multiplier 41 . Further, a sound 
system 44 audfoly reproduces the analog tone signal supplied from the D/A converter 43. The multiplier 41 outputs dig- 
ital tone data for each timing when the D/A converter effects the analog conversion at the fixed reproducing rate (fixed 
sampling frequency). A block denoted by reference numeral 45 represents a plurality of tone color switches (SW) each 
30 provided for the user to select a desired color of a tone to be generated, and a block denoted by reference numeral 46 
is a detection circuit for detecting the user operation of one of the tone color switches so as to output a tone color 
number TC corresponding to the user selected tone color. 

The electronic musical instrument operates in the following manner. When the player depresses any one of the 
keys on the keyboard 31 , the detection circuit 32 detects the depressed key to generate and provide the note number 
35 NN of the depressed key and note-on i signal NON to the pitch envelope generator 33, tone volume envelope generator ' 
42, original pitch generator 37 and address generator 38. In response to this, the pitch envelope generator 33 and tone 
volume envelope generator 42 start generating pitch envelope waveform AP and tone volume envelope waveform AEG, 
respectively, the original pitch generator 37 generates original pitch data OP, and the address generator 38 a read 
address composed of an integer portion ADI and decimal portion ADF. 
40 Assume here that waveform data are pre-recorded in the waveform memory 39 with the sampling frequency Fs var- 
ied in the manner shown in Fig. 1 9 and that the player has designated a key of the same pitch as of the recorded wave- 
form data 

In this case, the original pitch data generator 37 generates original pitch data OP expressed in the same cent value 
as the note number NN output from the detection circuit 32. Here, a data value output from the subtracter 5 (i.e., NN - 
45 OP) is approximately n 0" cent if a pitch envelope waveform AP far smaller than the note number NN is ignored. Upon 
receipt of the "0" cent data, the frequency number generator 36 outputs "1" as an F number. 

The address generator 38, by accumulating each F number output from the f requency number generator 36,a read 
address composed of an integer portion ADI and decimal portion ADF. The integer portion ADI of the read address 
increments by one for each sampling period of the D/A converter from the note-on timing, like SD, SD + 1 , SD + 2, SD 
so + 3, ... if the start address is "SD", while the decimal portion ADF of the read address is constantly maintained at "O". 

Each time the integer portion ADI is given to the waveform memory 39, the stored waveform sample data is read 
out from the memory 39. Because the decimal portion ADF of the read address is "0", the read-out waveform sample 
data MSD is passed through the interpolation circuit 40 to the multiplier 41 , which in turn multiples the sample data MSD 
by the tone volume envelope waveform AEG and the resultant multiplied data to the D/A converter 43. The D/A con- 
55 verter 43 converts the waveform sample data MSD into an analog tone signal at a fixed reproducing rate, and the ana- 
log tone signal is audible reproduced or sounded through the sound system 44. 

Because the individual integer portions ADI are generated as successive addresses, all the recorded waveform 
sample data are read out from the waveform memory 39, and the waveform data reproduced at the fixed reproducing 
rate will be of the same pitch as when recorded. 
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When the player depresses a key of a note name different from the recorded note name, a note number NN corre- 
sponding to the note name and octave code of the depressed key is output from the detection circuit 32 to the frequency 
number generator 36 (for example, where a key higher than the recorded pitch by a whole tone is depressed, the detec- 
tion circuit 32 outputs a note number NN incremented by 200 cents). The key number generator 36 in turn generates 

5 an F number corresponding to the depressed note name and octave code (e.g., higher than the recorded pitch by a 
whole tone) and passes the generated F number to the address generator 38. On the basis of a read address gener- 
ated this time, waveform sample data MSD is read out from the waveform memory 39 to be subjected to an interpolation 
process. In this interpolation process, interpolation such as linear interpolation is effected between successive wave- 
form sample data MSD in accordance with the decimal portion SDF. 

10 The thus-interpolated sample data ISD is multiplied via the multiplier 41 by the tone envelope waveform and passed 
to the D/A converter, where the sample data ISD is restored to analog waveform data at the fixed reproducing rate. The 
restored waveform data will present a pitch corresponding to the F number (e.g., higher than the recorded pitch by a 
whole tone). 

The address generator 31 supplies the generated read address to the original pitch generator 37, which, on the 
is basis of original pitch control data selected in response to the tone color number TC and note number NN, detects when 
the read address arrives address Ad1 , Ad2 or Ad3. Thus, by such detection, the original pitch generator 37 sequentially 

changes the value of the original pitch data OP like NNO NN(720 Hz) -» NNO + 1 oct 

In the above-mentioned manner, the variation curve of the original pitch data OP as shown in Fig, 20 is reproduced 
in response to the read addresses. At address locations Ad1 and Ad2, for example, the original pitch generator 37 will 
20 generate original pitch data OP incremented from the last data OP by 700 cents and another 500 cents and supply 
these incremented original pitch data OP to the subtracter 35. In turn, at an address location past Ad2, 1 ,200 cents are 
subtracted from the note number added with the pitch envelope AP output from the adder 34. Because 1 ,200 cents cor- 
respond to one octave, a note number ( NN + AP - OP ) one octave lower than the F number generated at the point pre- 
ceding Ad1 is output at address location Ad2 and then supplied to the FN generator 36. Accordingly, the FN generator 
25 36 generates an F number corresponding to a pitch that is one octave lower than the F number generated at the time 
earlier than Ad1 , so that the address generator 38 generates a read address incremented at a rate corresponding to 
the F number. 

The integer portion AD I of the read address is supplied to the waveform memory 39 so that the recorded waveform 
sample data is read out, one sample data at each read timing. If, for example, the F number to address Ad1 is "1 the 

30 F number is made "0.5" from address Ad2, so that the integer address ADI of the read address generated from the 
address generator 38 changes like 0, 1 , 1, 2, 2, ... while the decimal portion ADF changes like 0.5, 0, 0.5, 0, ... (the start 
address is not considered here). The integer address ADI is supplied to the waveform memory 39 to read out waveform 
sample data MSD therefrom, and the read-out sample data MSD is supplied to the interpolation circuit 40 for the inter- 
polation based on the decimal portion ADI. 

35 At and after address Ad2, the waveform sample data are read out from the waveform memory 39 every sampling 
cycle and interpolated by the interpolation circuit 40 in accordance with the individual decimal portions ADF. However, 
because the amount of the waveform sample data recorded in the waveform memory 39 at and after address Ad2 is, 
from the beginning, half the amount recorded up to address Ad 1 in the time axis (address) direction, the recorded wave- 
form sample data are read out from the waveform memory 39, one sample every other readout timing. This compen- 

40 sates for the halved sampling frequency Fs used for recording, so that the waveform sample data can be read out from 
the waveform memory 39 at the same pitch as when recorded. 

Then, the interpolated sample data ISD from the interpolation circuit 40 is multiplied via the multiplier 41 by the tone 
volume envelope waveform AEG generated by the tone volume envelope generator 42 and is converted via the D/A 
converter 43 into analog representation at the fixed reproducing rate. 

45 It should be noted here that when compressing the waveform data, the sampling frequency Fs for recording wave- 
form data from the start to end of a tone can be varied not only in a stepwise fashion as shown in Fig. 1 9 but also in a 
consecutive gradual fashion as shown in Fig. 24. In Fig. 24, the sampling frequency Fs is varied to lower consecutively 
from 48 kHz at time point t4 to 24 kHz at time point t5, and such a continuous variation also allows the waveform data 
to be recorded in the waveform memory in compressed form. In this case, the original pitch data OP expressed in cents 

so is set to vary linearly from the start to end of the tone. That is, when the waveform data read out from the waveform 
memory are reproduced at the fixed reproducing rate, the pitch of the reproduced waveform data varies linearly from 
address Ad4 to address Ad5 along the cent axis as shown in Fig. 25. 

Thus, where waveform data are recorded with the sampling frequency varied as shown in Fig. 25, the original pitch 
generator 37 of the electronic musical instrument shown in Fig. 23 only needs to output original pitch data OP varying 

55 in a broken-line fashion and hence can be substantially simplified in construction. 

In the arrangement for recording waveform sample data in the waveform memory in accordance with the waveform 
data corrpressing method of the present invention and the electronic musical instrument including such a waveform 
memory having waveform sample data recorded therein, the functions denoted in blocks can of course be implemented 
by hardware components, but may also be implemented by a MPU (micro processor unit) or a DSP (digital signal proc- 
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essor). 

According to the present invention described so far, the sampling frequency is raised for the attack portion of a tone 
to be recorded where the waveform data contain high frequency components and lowered for the sustain portion etc. 
where the waveform data contain not so high frequency components, so that waveform sample data to be recorded in 
the waveform memory can be effectively reduced in quantity and compressed to a substantial degree. As a result, the 
present invention can reduce a storage capacity of the waveform memory and use the memory with enhanced effi- 
ciency. 

Claims 

1 . A tone generating method for forming tone waveform samples on the basis of waveform forming calculations via an 
arithmetic processing device, characterized in that a resolution of the waveform forming calculations is determined 
independently for each of a plurality of tone generating channels in accordance with a character of a waveform to 
be formed in said channel and importance of said channel relative to other said channel. 

2. A tone generating method for forming tone waveform samples on the basis of waveform forming calculations via an 
arithmetic processing device, characterized in that a resolution of the waveform forming calculations is varied dur- 
ing the calculations in accordance with a time-varying ratio of harmonic content in a waveform sample. 

3. A tone generating method wherein tone forming calculations are performed for a plurality of tone generating chan- 
nels so as to form waveform data of a plurality of tones corresponding to the channels, said method comprising: 

a tone control step of generating first control data for, for each of the tone generating channels, designating a 
tonal characteristic of the waveform data to be formed in said channel; 

a calculation control step of generating second control data for, for each of the tone generating channels, des- 
ignating a specific number of tone samples to be formed in said channel per unit time; 
a tone formation step of. for each of the tone generating channels, arithmetically forming waveform data of the 
tone corresponding to said channel in accordance with the tonal characteristic designated by said first control 
data and at a sample forming rate designated by said second control data; and 

a step of generating tones on the basis of the waveform data formed in said tone formation step for the plurality 
of tone generating channels. 

4. A tone generating method as defined in claim 3 wherein said calculation control step generates said second control 
data in correspondence with the tonal characteristic of the waveform data to be formed in each of the tone gener- 
ating channels. ' 

5. A tone generating method as defined in claim 3 wherein said calculation control step varies said second control 
data to be generated, in correspondence with a time-variation in the tonal characteristic of the waveform data to be 
formed in each of the tone generating channels. 

6. A tone generating method as defined in claim 3 wherein said first control data includes pitch information that des- 
ignates a pitch of a tone to be generated in each of the tone generating channels, and wherein said tone formation 
step converts the pitch information of each of the channels into a phase variation rate of the tone to be generated, 
in accordance with the sample forming rate designated by said second control data. 

7. A tone generating method for simultaneously generating at least two tones, comprising: 

a first formation step of forming samples of a first tone waveform containing a great number of high-frequency 
components at a forming rate of N samples per unit time; 

a second formation step of forming samples of a second tone waveform containing a small number of high-fre- 
quency components at a forming rate of M samples per unit time, where M is smaller than N; 
a step of subjecting the M samples of said second tone waveform to an interpolation operation, so as to provide 
N samples of said second tone waveform; 

a mix step of sequentially adding the N samples of said first second tone waveform and the N samples of said 
second tone waveform sample by sample, so as to provide N samples of a mixed tone waveform; and 
a step of generating tones on the basis of the mixed tone waveform provided by said mix step. 

8. A tone generating method wherein tone forming calculations are performed for a plurality of tone generating chan- 
nels so as to form waveform data of a plurality of tones corresponding to the channels, said method comprising: 
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a division step of dividing the plurality of tone generating channels into first and second groups; 
a first formation step of forming N samples of a tone waveform per unit time for each of the channels of said 
first group and sequentially adding the N samples between the channels, so as to provide N samples of a first 
mixed waveform; 

5 a second formation step of forming M samples of a tone waveform per unit time tor each of the channels in said 

second group and sequentially adding the M samples between the channels, so as to provide M samples of a 
second mixed waveform, where M is smaller than N; 

a step of subjecting the M samples of said second tone waveform to an interpolation operation, so as to provide 
N samples of said second tone waveform; 
w a mix step of sequentially adding the N samples of said first second tone waveform and the N samples of said 

second tone waveform sample by sample, so as to provide N samples of a mixed tone waveform; and 
a step of generating tones on the basis of the mixed tone waveform provided by said mix step. 

9. A method for forming waveform sample data corresponding to a desired sound comprising a step of. at a variable 
is sampling rate determined in accordance with harmonic components contained in the sound to be formed in a given 
time section, forming waveform sample data for the given time section, wherein for each of a plurality of time sec- 
tions, waveform sample data are formed at a variable sampling rate depending on the harmonic components con- 
tained in the sound. 

20 1 0. A method wherein a desired sound is divided into a plurality of time sections and waveform sample data are formed 
for each of the time sections, comprising the steps of: 

defining resolution of waveform samples to be formed in each of the time sections independently of other said 
time section and performing arithmetic operations to form waveform sample data for each of the time sections 
25 with the resolution defined for said time section; and 

outputting the waveform sample data formed by said step of defining resolution. 

1 1 . A method as defined in claim 1 0 wherein said step of defining resolution forms a specific number of waveform sam- 
ple data corresponding to the defined resolution, using an optional time within the time section, and wherein said 

30 step of outputting temporarily buffers the waveform sample data formed using the optional time and reads out the 
buffered waveform sample data at a desired reproducing rate. 

12. A method for forming waveform sample data corresponding to desired sounds in a plurality of channels, comprising 
the steps of: 

35 *'"■■ ' 

forming waveform sample data in each of the channels at a sampling rate determined independently for each 
of the channels; and 

outputting resampled waveform sample data by resampling the waveform sample data formed in individual 
ones of the channels by use of a common sampling frequency. 

40 

13. A method as defined in claim 12 wherein said step of outputting includes adding together the resampled waveform 
sample data of the individual channels. 

14. A method as defined in claim 12 wherein said step of outputting includes interpolating between the waveform sam- 
45 pie data. 

15. A method as defined in claim 12 wherein the sampling rate for each of the channels is variably determined depend- 
ing on a time section of the sound to be generated in said channel. 

so 16. A sound generating device comprising: 

an arithmetic processing section for dividing a sound to be generated into a plurality of time sections, and inde- 
pendently for each of the time sections, defining resolution of waveform samples to be formed in said time sec- 
tion, so as to form waveform sample data corresponding to said time section with the resolution defined for said 
55 time section; and 

an output section for outputting the waveform sample data formed by said arithmetic processing section, said 
output section variably controlling a time width of each of the samples. 

17. A sound generating device as defined in claim 1 6 wherein said arithmetic processing section forms waveform sam- 
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pie data of a sound to be generated in each of the channels, with the resolution defined independently for said 
channel. 

18. A machine readable recording medium containing a group of instructions to cause said machine to implement a 
s sound generating method, said method performing tone forming calculations for a plurality of tone generating chan- 
nels so as to form waveform data of a plurality of tones corresponding to the channels, said method comprising: 

a tone control step of generating first control data for, for each of the tone generating channels, designating a 
tonal characteristic of the waveform data to be formed in said channel; 

w a calculation control step of generating second control data for, for each of the tone generating channels, des- 

ignating a specific number of tone samples to be formed in said channel per unit time; 
a tone formation step of, for each of the tone generating channels, arithmetically forming waveform data of the 
tone corresponding to said channel in accordance with the tonal characteristic designated by said first control 
data and at a sample forming rate designated by said second control data; and 

is a step of generating tones on the basis of the waveform data formed in said tone formation step for the plurality 

of tone generating channels. 

19. A machine readable recording medium containing a group of instructions to cause said machine to implement a 
sound generating method, said method simultaneously generating at least two tones, said method comprising: 

20 

a first formation step of forming samples of a first tone waveform containing a great number of high-frequency 
components at a forming rate of N samples per unit time; 

a second formation step of forming samples of a second tone waveform containing a small number of high-fre- 
quency components at a forming rate of M samples per unit time, where M is smaller than N; 
25 a step of subjecting the M samples of said second tone waveform to an interpolation operation, so as to provide 

N samples of said second tone waveform; 

a mix step of sequentially adding the N samples of said first second tone waveform and the N samples of said 
second tone waveform sample by sample, so as to provide N samples of a mixed tone waveform; and 
a step of generating tones on the basis of the mixed tone waveform provided by said mix step. 

30 

20. A machine readable recording medium containing a group of instructions to cause said machine to implement a 
sound generating method, said method performing tone forming calculations for a plurality of tone generating chan- 
nels so as to form waveform data of a plurality of tones corresponding to the channels, said method comprising: 

35 a division step of dividing the plurality of tone generating channels into first and second groups; 

a first formation step of forming N samples of a tone waveform per unit time for each of the channels in said 
first group and sequentially adding the N samples between the channels, so as to provide N samples of a first 
mixed waveform; 

a second formation step of forming M samples of a tone waveform per unit time for each of the channels in said 
40 second group and sequentially adding the M samples between the channels, so as to provide M samples of a 

second mixed waveform, where M is smaller than N; 

a step of subjecting the M samples of said second tone waveform to an interpolation operation, so as to provide 
N samples of said second tone waveform; 

a mix step of sequentially adding the N samples of said first second tone waveform and the N samples of said 
45 second tone waveform sample by sample, so as to provide N samples of a mixed tone waveform; and 

a step of generating tones on the basis of the mixed tone waveform provided by said mix step. 

21 . A waveform data compressing method comprising: 

so an input step of inputting a waveform lasting for a predetermined period; 

a control step of varying a recording sanpling frequency during said predetermined period; 
a sampling step of sampling the waveform by use of said recording sampling frequency so as to obtain wave- 
form data; and 

a write step of sequentially writing into a memory the waveform data obtained by said sampling stepi 

55 

22. A waveform data compressing method as defined in claim 21 wherein the recording sampling frequency is varied 
stepwise at predetermined timing during the predetermined period. 

23. A waveform data compressing method as defined in claim 21 wherein the recording sampling frequency is varied 
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gradually at predetermined timing during the predetermined period. 



24. A waveform data compressing method comprising: 



an input step of inputting a waveform lasting for a predetermined period; 
a control step of varying a recording sampling frequency during said predetermined period; 
a sampling step of sampling the waveform by use of the recording sampling frequency so as to obtain wave- 
form data; 

a recording step of sequentially recording into a waveform memory the waveform data obtained by said sam- 
pling step; 

a designation step of designating a reproducing rate; 

a generation step of generating variation data corresponding to a pitch variation occurring in the waveform data 
recorded in the waveform memory due to a variation of the recording sampling frequency by said control step; 
a modification step of modifying the reproducing rate designated by said designation step with the variation 
data; and 

a reproduction step of reading the waveform memory at a rate corresponding to the reproducing rate modified 
by said modification step. 

25. A waveform data compressing method as defined in claim 24 wherein where the waveform data are read out at a 
fixed rate, said variation data is data indicative of a frequency in a logarithmic region represented by the waveform 
data. . 

26. A waveform data compressing method as defined in claim 25 wherein said modification step performs addition or 
subtraction between the reproducing rate and the variation data. 



27. A machine readable recording medium containing a group of instructions to cause said machine to implement a 
sound generating method, said method comprising: 

an input step of inputting a waveform lasting for a predetermined period; 
a control step of varying a recording sampling frequency during said predetermined period; 
a sampling step of sampling the waveform by use of said recording sampling frequency so as to obtain wave- 
form data; and 

a write step of sequentially writing into a memory the waveform data obtained by said sampling step. 

28. A machine readable recording medium containing a group of instructions to cause said machine to implement a 
sound generating method, said method comprising: 

an input step of inputting a waveform lasting for a predetermined period; 
a control step of varying a recording sampling frequency during said predetermined period; 
a sampling step of sampling the waveform by use of the recording sampling frequency so as to obtain wave- 
form data; 

a recording step of sequentially recording into a waveform memory the waveform data obtained by said sam- 
pling step; 

a designation step of designating a reproducing rate; 

a generation step of generating variation data corresponcfing to a pitch variation occurring in the waveform data 
recorded in the waveform memory due to a variation of the recording sampling frequency by said control step; 
a modification step of modifying the reproducing rate designated by said rate designation step with the varia- 
tion data; and 

a reproduction step of reading the waveform memory at a rate corresponding to the reproducing rate modified 
by said modification step. 
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